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CLAIMS 



1. (previously presented) A browser-based method for filling out an electronic 
5 form automatically without use of a stored map of said form, comprising the steps 

of: 

mapping said form by said browser based on analysis of at least one 
visible form element proximate at least one form field by analyzing text within a 
configurable area of a page containing said form, said page comprising an 
10 untransformed HTML page, and 

populating said at least one form field with data retrieved according to 
said mapping a format specified by said mapping without user intervention in 
correct format without user intervention. 

15 2. (previously presented) The method of claim 1, wherein analyzing text 
expressions comprises the steps of: 

identifying fields based on analysis of visible field labels proximate said at 
least one field, when said field labels are present; and 

evaluating user visible display format hints proximate said fields to 
20 determine required display format. 

3. (previously presented) The method of claim 2, wherein said step of 
identifying fields based on analysis of visible field labels comprises: 

traversing form elements in a first sequence. 

25 

4. (previously presented) The method of claim 3, wherein said step of 
identifying fields based on analysis of visible field labels further comprises any of 
the steps of: 

if a field is positioned in a table cell, analyzing text expressions in adjacent 

30 cells; 
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analyzing a text expression within a predetermined number of words and 
in at least one predetermined direction from said fields; 

based on page coordinates, examining said page in general vicinity of the 
field in all directions from the field and analyzing text expression closest to said 
5 field; and 

disregarding text expressions embedded within parentheses or quotation 

marks. 

5. (original) The method of claim 4, wherein said step of identifying fields 
10 based on analysis of visible field labels further comprises the step of: 

comparing the analyzed text expressions with entries in a field label 
dictionary to find closest match with a metadata expression, wherein said field is 
mapped to correct metadata. 

15 6. (original) The method of claim 3, further comprising the step of: 

when a field lacks a visible field label, mapping the field according to 
context. 

7. (original) The method of claim 6, wherein mapping the field according to 
20 context comprises: 

identifying mapping of at least one field preceding a current field in said 
first sequence; and 

mapping said current field based on said mapping of said preceding field. 

25 8. (original) The method of claim 3, further comprising the step of: 

when a field lacks a visible field label, mapping the field based on analysis 
of a programmatic field name. 

9. (original) The method of claim 3, further comprising the step of: 
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when a field lacks a visible field label, comparing the field's default value 
with entries in a field label dictionary to find closest match with a metadata 
expression, wherein said field is mapped to correct metadata. 

5 10. (original) The method of claim 3, further comprising the step of: 

if a field Is a select field, comparing selection options with entries In a field 
label dictionary to find closest match with a metadata expression, wherein said 
field is mapped to correct metadata. 

10 11. (original) The method of claim 3, further comprising the step of: 
for sets of radio buttons, creating a new object for each set. 

12. (original) The method of claim 3, further comprising the step of: 
identifying block type, wherein a block comprises a plurality of related 

15 fields. 

13. (original) The method of claim 12, wherein the step of identifying block 
type comprises one of the steps of: 

comparing programmatic field name of at least a current field with arrays 
20 of metadata expressions for each block type; 

comparing visible form elements for at least said current field with arrays 
of metadata expressions for each block type; and 

where said current field occupies a table cell, analyzing text expressions 
at least from first cell of said table to cell occupied by said current field. 

25 

14. (previously presented) The method of claim 13, said step of identifying 
block type further comprising the step of: 

when a close match is found, mapping said field to.said block type. 

30 1 5. (original) The method of claim 1 2, wherein block type includes any of: 
billing address; 
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shipping address; 

credit card information; and 

email address. 

5 16. (original) The method of claim 2, further comprising the step of: 

traversing form elements in a second sequence, said second sequence a 
reverse of a first sequence; 

identifying mapping of at least a field following a current field in said 
second sequence; and 
10 mapping said current field based on said mapping of said following field. 



17. (currently amended) The method of claim 2, wherein said step of 
evaluating visible display format hints proximate said fields to determine required 
display format comprises the steps of: 

15 traversing form elements in a first sequence; 

analyzing a visible display format hint proximate a field; 
comparing said analyzed display format hint with a dictionary of data-entry 
prompts; and 

mapping said field to a display format based on said comparison. 

20 

18. (previously presented) The method of claim 17, further comprising the 
step of: 

any of concatenating, truncating and re-foimatting said retrieved data 
according to said display format 

25 

1 9. (original) The method of claim 17, further comprising the step of: 

for a field lacking a proximate visible display format hint, mapping current 
field to same display format of a preceding field if both fields are the same field 
type. 

30 
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20. (original) The method of claim 1 , further comprising the step of: identifying 
a form as a checkout form. 

21 . (original) The method of claim 1 , further comprising the step of: 



22. (currently amended) A computer program product for filling out an 
electronic form automatically without use of a stored map of said form, said 
computer program product comprising a tangibl e computer-readable medium 

10 having computer readable code embodied thereon, the computer code including 
program code means for: 

mapping said form by a browser based on analysis of at least one visible 
form element proximate a form filed by analyzing test expressions located within 
a configurable area of a page containing said form, said page comprising an 

15 untransformed HTML page; and 

populating said at least one form field by said browser with data retrieved 
according to said mapping in a format specified by said mapping without user 
intervention. 

20 23. (original) The computer program product of claim 22, wherein said code 

means for mapping said form based on analysis of visible form elements 

comprises code means for: 

identifying fields based on analysis of visible field labels proximate said 

fields, when said field labels are present; and 
25 evaluating user visible display format hints proximate said fields to 

determine required display format. 

24. (previously presented) The computer program product of claim 23, 
wherein said code means for identifying fields based on analysis of visible field 
30 labels comprises code means for. 

traversing form elements in a first sequence. 



5 



masking confidential data from being displayed. 
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25. (previously presented) The computer program product of claim 24, 
wherein said code means for identifying fields based on analysis of visible field 
labels further comprises code means for any of: 
5 if a field is positioned in a table cell, analyzing text expressions in adjacent 

cells; 

analyzing a text expression within a predetermined number of words and 
in at least one predetermined direction from said fields; 

based on page coordinates, examining said page in general vicinity of the 
10 field in all directions from the field and analyzing text expression closest to said 
field; 

and disregarding text expressions embedded within parentheses or 
quotation marks. 

15 26. (original) The computer program product of claim 25, wherein said code 
means for identifying fields based on analysis of visible field labels further 
comprises code means for: 

comparing the analyzed text expressions with entries In a field label 
dictionary to find closest match with a metadata expression, wherein said field is 

20 mapped to correct metadata. 

27. (original) The computer program product of claim 24, further comprising 
code means for 

when a field lacks a visible field label, mapping the field according to 
25 context. 

28, (original) The computer program product of claim 27, wherein said code 
means for mapping the field according to context comprises code means for: 

identifying mapping of at least one field preceding a current field in said 
30 first sequence; and 

mapping said current field based on said mapping of said preceding field. 
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29. (original) The computer program product of claim 24, further comprising 
code means for: 

when a field lacks a visible field label, mapping the field based on analysis 
5 of a programmatic field name. 

30. (original) The computer program product of claim 24, further comprising 
code means for. 

when a field lacks a visible field label, comparing the field's default value 
10 with entries in a field label dictionary to find closest match with a metadata 
expression, wherein said field is mapped to correct metadata. 

31. (original) The computer program product of claim 24, further comprising 
code means for: 

15 if a field is a select field, comparing selection options with entries in a field 

label dictionary to find closest match with a metadata expression, wherein said 
field is mapped to correct metadata. 

32. (original) The computer program product of claim 24, further comprising 
20 code means for: 

for sets of radio buttons, creating a new object for each set. 

33. (original) The computer program product of claim 24, further comprising 
code means for: 

25 identifying block type, wherein a block comprises a plurality of related 

fields. 

34. (original) The computer program product of claim 33, wherein the code 
means for identifying block type comprises code means for 

30 comparing programmatic field name of at least a current field with arrays 

of metadata expressions for each block type; 

Page 8 of 21 



PAGE 9/22* RCVD AT 10/23/2006 9:41:15 PM [Eastern Daylight Time] * SVR:USPTO-EFXRF-2/10 * DNIS:273830fl * CSID:650 474 8401 1 DURATION (mm-ss):0644 



10/23/2006 MON 18:44 FAX 650 474 8401 GLENN PATENT GROUP 



@010/022 



Application ser no. 10/680,659 

comparing visible form elements for at least said current field with arrays 
of metadata expressions for each block type; and 

where said current field occupies a table cell, analyzing text expressions 
at least from a first cell of said table to a cell occupied by said current field. 

5 

35. (original) The computer program product of claim 34, wherein the code 
means for identifying block type further comprises code means for: 

when a close match is found, mapping said field to said block type. 

10 36. (original) The computer program product of claim 33, wherein block type 
includes any of: 

billing address; 

shipping address; 

credit card information; and 
15 email address. 

37. (original) The computer program product of claim 23, further comprising 
code means for: 

traversing form elements in a second sequence, said second sequence a 
20 reverse of a first sequence; 

Identifying mapping of at least a field following a current field in said 
second sequence; and 

mapping said current field based on said mapping of said following field. 

25 38. (original) The computer program product of claim 23, wherein said code 
means for evaluating visible display format hints proximate said fields to 
determine required display format comprises code means for 
traversing form elements in a first sequence; 
analyzing a visible display format hint proximate a field; 
30 comparing said analyzed display format hint with a dictionary of data-entry 

prompts;. 
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mapping said field to a display format based on said comparison. 

39. (previously presented) The computer program product of 38, further 
comprising the code means for: 

5 any of concatenating, truncating and re-formatting said retrieved data 

according to said display format. 

40. (original) The computer program product of claim 38, further comprising 
code means for: 

10 for a field lacking a proximate visible display format hint, mapping current 

field to same display format of a preceding field if both fields are the same field 
type. 

41. (original) The computer program product of claim 22, further comprising 
15 code means for: 

identifying a form as a checkout form. 

42. (original) The computer program product of claim 22, further comprising 
code means for: 

20 masking confidential data from being displayed. 

43. (previously presented) A client-based system for filling out an electronic 
form automatically without previously mapping or examining said form, 
comprising: 

25 a browser; 

at least one data file; 

rules for mapping visible form elements to correct data from said file; and 
computer-readable code means for: 

mapping said form by said browser based on analysis of at least 
30 one visible form element proximate at least one form field by analyzing 

text expression located within a configurable area of a page containing 
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said form said page comprising an untransformed HTML page; and 

populating said at least one form field by said browser with data 
retrieved according to said mapping in a format specified by said mapping 
in correct format without user intervention; 
5 wherein said code is executable on a client running said browser, and 

wherein said rules, and said code are stored on said client. 

44. (original) The system of claim 43, wherein said code means for mapping 
said form based on analysis of visible form elements comprises code means for: 
10 identifying fields based on analysis of visible field labels proximate said 

fields, when said field labels are present; and 

evaluating user visible display format hints proximate said fields to 
determine required display format. 

15 45. (previously presented) The system of claim 44, wherein said code means 
for identifying fields based on analysis of visible field labels comprises code 
means for 

traversing form elements in a first sequence. 

20 46. (previously presented) The system of claim 45, wherein said code means 
for identifying fields based on analysis of visible field labels further comprises 
code means for any of: 

if a field is positioned in a table cell, analyzing text expressions in adjacent 

cells; 

25 analyzing a text expression within a predetermined number of words and 

in at least one predetermined direction from said fields; 

based on page coordinates, examining said page in general vicinity of the 
field in all directions from the field and analyzing text expression closest to said 
field; and 

30 disregarding text expressions embedded within parentheses or quotation 

marks. 
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47. (original) The system of claim 46, wherein said code means for identifying 
fields based on analysis of visible field labels further comprises code means for: 

comparing the analyzed text expressions with entries in a field label 
5 dictionary to find closest match with a metadata expression, wherein said field is 
mapped to correct metadata. 

48. (original) The system of claim 45, further comprising code means for: 
when a field lacks a visible field label, mapping the field according to 

10 context. 

49. (original) The system of claim 48, wherein said code means for mapping 
the field according to context comprises code means for: 

identifying mapping of at least one field preceding a current field in said 
15 first sequence; and 

mapping said current field based on said mapping of said preceding field. 

50. (original) The system of claim 45, further comprising code means for: 
when a field lacks a visible field label, mapping the field based on analysis 

20 of a programmatic field name. 

51. (original) The system of claim 45, further comprising code means for: 
when a field lacks a visible field label, comparing the field's default value 

with entries in a field label dictionary to find closest match with a metadata 
25 expression, wherein said field is mapped to correct metadata. 

52. (original) The system of claim 45, further comprising code means for: 

if a field is a select field, comparing selection options with entries in a field 
label dictionary to find closest match with a metadata expression, wherein said 
30 field is mapped to correct metadata. 
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53. (original) The system of claim 45, further comprising code means for: 
for sets of radio buttons, creating a new object for each set. 

54. (original) The system of claim 24, further comprising code means for 
5 identifying block type, wherein a block comprises a plurality of related 

fields. 

55. (original) The system of claim 54, wherein the code means for identifying 
block type comprises code means for: 

10 comparing programmatic field name of at least a current field with arrays 

of metadata expressions for each block type; 

comparing visible form elements for at least said current field with arrays 
of metadata expressions for each block type; and 

where said current field occupies a table cell, analyzing text expressions 
15 at least from first cell of said table to cell occupied by said current field. 

56. (original) The system of claim 55, wherein the code means for identifying 
block type further comprises code means for: 

when a close match is found, mapping said field to said block type. 

20 

57. (original) The system of claim 54, wherein block type includes any of: 
billing address; 

shipping address; 
credit card information; and 
25 email address. 

58. (currently amended) The system of claim 44, further comprising code 
means for: 

traversing form elements in a second sequence, said second sequence a 
30 reverse of a first sequence; 
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identifying mapping of at least a field following a current field in said 
second sequence; and 

mapping said current field based on said mapping of said following field. 

5 59. (original) The system of claim 44, wherein said code means for evaluating 
visible display format hints proximate said fields to determine required display 
format comprises code means for 

traversing form elements in a first sequence; 
analyzing a visible display format hint proximate a field; 
10 comparing said analyzed display format hint with a dictionary of data-entry 

prompts; 

mapping said field to a display format based on said comparison. 

60. (previously presented) The system of 59, further comprising code means 
15 for any of concatenating, truncating and re-formatting said retrieved data 

according to said display format. 

61 . (original) The system of claim 59, further comprising code means for: 

for a field lacking a proximate visible display format hint, mapping current 
20 field to same display format of a preceding field if both fields are the same field 
type. 

62. (original) The system of claim 43, further comprising code means for: 
identifying a form as a checkout form. 

25 

63. (original) The system of claim 43, further comprising code means for: 
masking confidential data from being displayed. 

64. (original) The system of claim 43, wherein said data file resides on said 
30 client or on a server. 
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